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FCC APPROVAL 

This equipment generates and uses radio frequency energy and, if not installed and used properly, 
that is, in strict accordance with the manufacturer's instructions, may cause interference to radio 
and television reception. It has been type tested and found to comply with the limits for a Class B 
computing device in accordance with the specifications in Subpart J of Part 15 of FCC Rules, 
which are designed to provide reasonable protection against such interference in a residential 
installation. However, there is no guarantee that interference will not occur in a particular 
installation. If this equipment does cause interference to radio or television reception, which can be 
determined by turning the equipment off and on, the user is encouraged to try to correct the 
interference by one or more of the following measures: 

Re-orient the receiving antenna 

Relocate the computer with respect to the receiver 

Move the computer away from the receiver 

Plug the computer into a different outlet so that computer and receiver are on different 

branch circuits. 

If necessary, the user should consult the dealer or an experienced radio/television technician for 
additional suggestions. The user may find the following booklet prepared by the Federal 
Communications Commission helpful: 

"How to Identify and Resolve Radio-TV Interference Problems". 

This booklet is available from the U.S. Government Printing Office, Washington, DC 20402, 
Stock No. 004-000-00345-4. 



SECTION 1 

INTRODUCTION 

1.1. PRODUCT DESCRIPTION 

The OMTI 8240 controller is a a combination of Winchester disk and floppy disk controllers for 
IBM AT Bus compatible computers (16 bit data path). The controller is contained on a single PCB 
that plugs into an empty slot of the motherboard of the computer. 

The OMTI controllers use SMS' sophisticated VLSI circuitry to provide many advanced features. 
These include: 

-Support for high capacity (1.2 Megabyte) floppies. 

-High performance (1:1 interleave on disk, X.X Megabyte/second transfer on 
AT Bus). 

•2Kbyte buffer minimum. 

-32 bit Error Correction Code on ST412 (MFM encoding) drives. 

-Concurrent data operations on Winchester and floppy disk on the 8240. 

1.2 NUMBER AND TYPE OF DRIVES SUPPORTED 

Table 1-1 

Model 8240 

Number of drives 4 max 

W+F 
Winchesters up to 2 

ST412 Recording MFM 

ESDI drives No 

Flexible disks Yes 
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1.3 SPECIFICATION 

1.3.1. Features per Peripherals 



WINCHESTER DISKS. 

- Operates one or two soft sectored ST412 compatible Winchester disk(s). 

- MFM encoded drives transfer data at 5 Mbit/sec. 

- Supports 128, 256, 512 and 1024 bytes/sector. 

- Supports programmable sector interleave including One to One interleave. 

• Addresses up to 2048 tracks (cylinders) and 16 heads. 

- Word (16 bits) width data transfer on AT bus. 

""floTpyBisks 

• Operates one or two floppy disk drives. 

- Supports 48 & 96 TPI drives plus the high density AT compatible drives. 



Supports 250, 300, or 500 K bits/sec transfer rate including dual 
rotational speed floppies. 

Host has direct access to floppy disk controller chip (NEC765 or 
equivalent). 



OMTI 8240 Controller Series - Revision A - Page 1-2 



1.3.2 Physical Specifications of the OMTI 8240 controller 



Width 3.9 inches 




Length 13.25 inches 
Height .75 inches 




1.3.3 Environmental Specifications 




Operating 


Storage 


Temperature to 50 deg C 
Relative Humidity 10 to 95% N.C. 
Maximum Wet Bulb 30 deg C 
Altitude to 10,000 ft. 


40 to 75 deg C 

10 to 95% Noncondensing 

Noncondensing 

to 15,000 ft. 



1.3.4. Power Requirements 



8240 



Voltage 

Maximum ripple and noise 

Maximum current drawn 



4.75 to 5.25 V DC 

100 mv 

1.0 Amp max 
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SECTION 2 
HOST ELECTRICAL INTERFACE 



2.1. INTRODUCTION 



The OMTI 8240 Series Data Controllers are electrically and mechanically compatible with the bus or 
Input/Output channel used in the IBM AT computer. Physically this Input/Output channel is 
contained on two card edge connectors. 

The Input/Output channel provides the necessary hardware interface to the host CPU to allow it to 
communicate with the controller. 

2.2 INPUT/OUTPUT CHANNEL PIN ASSIGNMENTS 

The following figures summarize pin assignments for the Input/Output channel connectors. 

INPUT/OUTPUT CHANNEL (COMPONENT SIDE of 62 pin EDGE CONNECTOR) 



| I/O 


Signal Name 


Input/Output | 

1 


1 Al 


-I/OCHCK 


I | 


j A2 


SD7 


I/O | 


| A3 


SD6 


I/O | 


| A4 


SD5 


I/O | 


| A5 


SD4 


I/O | 


| A6 


SD3 


I/O | 


1 A7 


SD2 


I/O | 


| A8 


SD1 


I/O | 


| A9 


SDO 


I/O I 


| A10 


I/OCHRDY 


I 1 


| All 


AEN 


I 


| A12 


SA19 


I/O I 


| A13 


SA18 


I/O I 


| A14 


SA17 


I/O I 


| A15 


SA16 


I/O I 


i A16 


SA15 


I/O I 


| A17 


SAM 


I/O I 


| A18 


SA13 


VO I 


| A19 


SA12 


I/O I 


| A20 


SA11 


I/O I 


| A21 


SA10 


I/O i 


| A22 


SA9 


I/O I 


| A23 


SA8 


I/O I 


| A24 


SA7 


I/O 1 


| A25 


SA6 


I/O ! 


| A26 


SA5 


I/O 1 


| A27 


SA4 


I/O | 


| A28 


SA3 


I/O I 


| A29 


SA2 


I/O 1 


| A30 


SA1 


I/O 1 


| A31 


SAO 


I/O I 
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Input/Output Channel (SOLDER SIDE of 62 pin EDGE CONNECTOR) 



| I/O Pin 


Signal Name 


I/O | 


1 Bl 


GND 


Ground | 


| B2 


RESET DRV 


O | 


| B3 


+5Vdc 


Power | 


| B4 


IRQ9 


I | 


| B5 


-5Vdc 


Power j 


| B6 


DRQ2 


I | 


1 B7 


-12Vdc 


Power | 


| B8 


-ows 


i i 


| B9 


+12 Vdc 


Power | 


| BIO 


GND 


Ground 


| Bll 


-SMEMW 


O | 


| B12 


-SMEMR 


O | 


| B13 


-IOW 


I/O | 


| B14 


-IOR 


I/O | 


| B15 


-DACK3 


o | 


| B16 


DRQ3 


I 1 


| B17 


-DACK1 


o | 


| B18 


DRQ1 


I 1 


| B19 


-Refresh 


I/O | 


| B20 


CLK 


o | 


| B21 


IRQ7 


I 1 


| B22 


IRQ6 


I 1 


| B23 


IRQ5 


I 1 


| B24 


IRQ4 


I 1 


| B25 


IRQ3 


I 1 


| B26 


-DACK2 


o | 


| B27 


T/C 


O | 


| B28 


BALE 


I 


| B29 


+5 Vdc 


Power | 


| B30 


OSC 


O ! 


| B31 


GND 


Ground | 

1 
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Input/Output Channel (COMPONENT SIDE of 36 pin EDGE CONNECTOR) 



| I/O Pin 

1 


Signal Name 


I/O | 


1 CI 


-SBHE 


I/O | 


| C2 


LA23 


I/O | 


| C3 


LA22 


vo \ 


1 C4 


LA21 


I/O ! 


| C5 


LA20 


I/O | 


| C6 


LA19 


I/O | 


! C7 


LA18 


I/O I 


| C8 


LAI 7 


vo \ 


| C9 


-MEMR 


VO | 


I CIO 


-MEMW 


I/O i 


| Cll 


SD08 


I/O | 


| C12 


SD09 


I/O | 


| C13 


SD10 


I/O | 


| C14 


SDH 


I/O | 


| C15 


SD12 


I/O | 


| C16 


SD13 


I/O | 


| C17 


SDH 


I/O ! 


| C18 


SD15 


I/O | 

1 



Input/Output Channel (SOLDER SIDE of 36 pin EDGE CONNECTOR) 



| I/O Pin 


Signal Name 


I/O | 

1 


1 Dl 


-MEMCS16 


I | 


| D2 


-I/O CS 16 


I | 


| D3 
| D4 
i D5 
| D6 
| D7 
| D8 


IRQIO 
IRQll 
IRQ12 
IRQ13 
IRQ 14 
-DACKO 


I ! 
I | 
I | 
I | 

I | 
| 


I D9 
| DIO 


DRQO 
-DACK5 


I | 
o | 


| Dll 
| D12 


DRQ5 
-DACK6 


I 1 
o | 


| D13 
| D14 


DRQ6 
-DACK7 


I ! 
O | 


| D15 
| D16 


DRQ7 

+5Vdc 


I | 
Power | 


| D17 


-MASTER 


I | 


| D18 


GND 


GND ! 

1 
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2.3 INPUT/OUTPUT CHANNEL SIGNAL DESCRIPTION 

The following is a description of the system board's INPUT/OUTPUT channel signals. All signal 
lines are TTL-compatible. Input/Output adapters should be designed with a maximum of two 
low-power Shottky (LS) loads per line. 

SAO through SA19 (Input/Output) 

Address bits through 19 are used to address memory and Input/Output devices within the 
system. These 20 address lines, in addition to LA17 through LA23, allow access of up to 16Mb 
of memory. SAO through SA19 are gated on the system bus when "BALE" is high and are 
latched on the falling edge of "BALE." These signals are generated by the microprocessor or 
DMA Controller. They also may be driven by other microprocessors or DMA controllers that 
reside on the Input/Output channel. 

LA17 through LA23 (Input/Output) 

These signals (unlatched) are used to address memory and Input/Output devices within the 
system. They give the system up to 16Mb of addressability. These signals are valid when 
"BALE" is high. LA 17 through LA23 are not latched during microprocessor cycles and therefore 
do not stay valid for the whole cycle. Their purpose is to generate memory decodes for 1 wait- 
state memory cycles. These decodes should be latched by Input/Output adapters on the falling 
edge of "BALE." These signals also may be driven by other microprocessors or DMA controllers 
that reside on the Input/Output channel. Note that it is these signals that are decoded by the 
Input/Output adapter to generate "MEM CS16" for 16 bit, 1 wait -state memory cycles. 

CLK (Output) . 

This is the 6-MHz system clock. It is a synchronous microprocessor cycle clock with a cycle time 
of 167 nanoseconds. The clock has a 50% duty cycle. This signal should only be used for 
synchronization. It is not intended for uses requiring a fixed frequency. 

RESET DRV (Output) 
"Reset drive" is used to reset or initialize system logic at power-up time or during a low hne- 
voltage outage. This signal is active high. 

SDO through SD15 (Input/Output) 

These signals provide bus bits through 15 for the microprocessor, memory, and Input/Output 
devices. DO is the least-significant bit and D15 is the most significant bit. All 8-bit devices on 
the Input/Output channel should use DO through D7 for communications to the microprocessor. 
The 16-bit devices will use DO through D15. To support 8-bit devices, the data on D8 through 
D15 will be gated to DO through D7 during 8-bit transfers to these devices; 16-bit microprocessor 
transfers to 8-bit devices will be converted to two 8-bit transfers. 

BALE (Output)(buffered) 

"Address latch enable" is provided by the 82288 Bus Controller and is used on the system board 
to latch valid addresses and memory decodes from the microprocessor. It is available to the 
Input/Output channel as an indicator of a valid microprocessor or DMA address (when used with 
AEN") Microprocessor addresses SAO through SA19 are latched with the falling edge of 
"BALE." "BAT P." is forced high during DMA cycles. Note: that "BALE" is usually used by the 
IO adapter only to latch the LA17-LA23 address lines (or the decode of LA17-LA23 that indicates 
an address match for the IO adapter). "BALE" may not occur on all 8-bit Input/Output cycles 
(which use only address lines SA0-SA9 for device decoding) or on some 8-bit memory transfers. 
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Input/Output CH RDY (Input) 
"Input/Output channel ready" is pulled low (not ready) by a memory or Input/Output device to 
lengthen Input/Output memory cycles. Any slow device using this line should drive it low 
immediately upon detecting its valid address and a Read or Write command. Machine cycles are 
extended by an integral number of clock cycles (167 nanoseconds). This signal should be held 
low for no more than 2.5 microseconds. 

IRQ3-IRQ7, IRQ9-IRQ12 and IRQ 14 through 15 (Input) 

Interrupt Requests 3 through 7, 9 through 12, and 14 are used to signal the microprocessor that 
an Input/Output device needs attention. These interrupt requests are prioritized, with IRQ9 
through IRQ 12 and IRQ 14 through IRQ15 having the highest priority (IRQ9 is the highest) and 
ERQ3 through IRQ7 having the lowest priority (IRQ7 is the lowest). An interrupt request is 
generated when an IRQ line is raised from low to high. The line must be held high until the 
microprocessor acknowledges the interrupt request (Interrupt Service routine). Interrupt 13 is 
used on the system board and is not available on the Input/Output channel. Interrupt 8 is used for 
the real-time clock. 

-IOR (Input/Output) 

Input/Output Read' instructs an Input/Output device to drive its data onto the databus. It may be 
driven by the system microprocessor or DMA controller, or by a microprocessor or DMA 
controller resident on the Input/Output channel. This signal is active low. 

-IOW (Input/Output) 

"-Input/Output Write" instructs an Input/Output device to read the data on the data bus. It may be 
driven by any microprocessor or DMA controller in the system. This signal is active low. 

-SMEMR (Output) -MEMR (Input/Output) 

These signals instruct the memory devices to drive data onto the data bus. "-SMEMR" is active 
only when the memory decode is within the low 1Mb of memory space. "-MEMR" is active on 
all memory read cycles. "-MEMR" may be driven by any microprocessor or DMA controller in 
the system. -SMEMR" is derived from "-MEMR" and the decode of the low 1 Mb of memory. 
When a microprocessor on the Input/Output channel wishes to drive "-MEMR", it must have the 
address lines valid on the bus for one system clock period before driving "-MEMR active. Both 
signals are active LOW. 

-SMEMW (Output) -MEMW (Input/Output) 

These signals instruct the memory devices to store the data present on the data bus. "-SMEMW" 
is active only when the memory decode is within the low 1Mb of the memory space. "-MEMW" 
is active on all memory read cycles. "-MEMW" may be driven by any microprocessor or DMA 
controller in the system. "-SMEMW" is derived from "-MEMW" and the decode of the low 1Mb 
of memory. When a microprocessor on the Input/Output channel wishes to drive "-MEMW", it 
must have the address lines valid on the bus for one system clock period before driving "- 
MEMW" active. Both signals are active low. 

DRQ0-DRQ3 and DRQ5-DRQ7 (Input) 

DMA Requests through 3 and 5 through 7 are asynchronous channel requests used by 
peripheral devices and the Input/Output channel microprocessors to gain DMA service (or control 
of the system). They are prioritized, with "DRQO" having the highest priority and "DRQ7" 
having the lowest A request is generated by bringing a DRQ line toan active level. ADRQJine 
must be held high until the corresponding "DMA Request Acknowledge" (DACK) line goes 
active. "DRQO" through "DRQ3" will perform 8-bit DMA transfers; "DRQ5" through "DRQ7" 
will perform 16-bit transfers. "DRQ4" is used on the system board and is not available on the 
Input/Output channel. 
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-DACK to -DACK3 and -DACK5 to -DACK7 (Output) 

-DMA Acknowledge to 3 and 5 to 7 are used to acknowledge DMA requests (DRQ) through 
DRQ7). They are active low. 

AEN (Output) 

"Address Enable" is used to degate the microprocessor and other devices from the Input/Output 
channel to allow DMA transfers to take place. When this line is active, the DMA controller has 
control of the address bus, the data-bus READ command lines (memory and Input/Output, and 
the Write command lines (memory and Input/Output). 

-REFRESH (Input/Output) 

This signal is used to indicate a refresh cycle and can be driven by a microprocessor on the 
Input/Output channel. 

T/C (Output) 

"Terminal Count" provides a pulse when the terminal count for any DMA channel is reached. 

•SBHE (Input/Output) 

"Bus High Enable" indicates a transfer of data on the upper byte of the data bus, SD8 through 
SD15. Sixteen-bit devices use "-SBHE" to condition data bus buffers tied to SD8 through SD15. 

-SBHE AND SAO ENCODINGS: 

-SBHE SAO FUNCTION 

WORD TRANSFER 

1 BYTE TRANSFER ON SD8-SD15 

1 BYTE TRANSFER ON SD0-SD7 
1 1 RESERVED 

-MASTER (Input) 
This signal is used with DRQ line to gain control of the system. A processor or DMA controller 
on the Input/Output channel may issue a DRQ to a DMA channel in cascade mode and receive a "- 
DACK". Upon receiving the "-DACK", an Input/Output microprocessor may pull "-MASTER" 
low, which will allow it to control the system address, data, and control lines (a condition known 
as tri-state). After -MASTER" is low, the Input/Output microprocessor must wait one system 
clock period before driving the address and data lines, and two clock periods before issuing a 
Read or Write command. If this signal is held low for more than 15 microseconds, system 
memory may be lost because of a lack of refresh. 

-MEM CS16 (Input) 

"-MEM 16 Chip Select" signals the system board if the present data transfer is a 1 wait-state, 16- 
bit memory cycle. It must be derived from the decode of LA 17 through LA23. Note that this 
requires that all 16-bit memory devices must occupy at least 128 kbytes of address space on the 
Bus and must not decode the SA address lines as a condition to driving "-MEM CS16" as the SA 
lines are not valid in time to meet the "-MEM CS16" timing requirements. "-MEM CS16" should 
be driven with an open-collector or tri-state driver capable of sinking 20 mA. 
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•Input/Output CS16 (Input) 
"-Input/Output 16 bit Chip Select" signals the system board that the present data transfer is a 16- 
bit, 1 wait-state, Input/Output cycle. It is derived from an address decode. "Input/Output CS16" 
is active low and should be driven with an open collector or tri-state driver capable of sinking 
20mA. 

OSC (Output) 

"Oscillator" (OSC) is a high-speed clock with a 70 nanosecond period (14.31818 MHz). This 
signal is not synchronous with the system clock. It has a 50% duty cycle. 

-OWS (Input) 

The "Zero Wait State" (-OWS) signal tells the microprocessor that it can complete the present bus 
cycle without inserting any additional wait cycles. In order to run a memory cycle to a 16-bit 
device without wait cycles, "-OWS" is derived from an address decode gated with a Read or 
Write command. In order to run a memory cycle to an 8-bit device with a minimum of two wait 
states, "-OWS" should be driven active one system clock after the Read or Write command is 
active gated with the address decode for the device. Memory Read and Write commands to an 8- 
bit device are active on the falling edge of the system clock. Note that "-OWS" must be 
synchronous to the system clock (CLK) and meet specific set-up and hold timing requirements to 
prevent undesirable system malfunction (see section 3.1.2.). "-OWS" is active low and should be 
driven with an open collector or tri-state driver capable of sinking 20mA. 

2.4 CONTROLLER HARDWARE ARCHITECTURE 

The OMTI 8240 series is partitioned into two distinct sections - the floppy disk logic and the 
Winchester disk logic. The first two sections share the same physical PCB board but are otherwise 
independent This allows full concurrent operations between these two sections. 



2.5 WINCHESTER TRACK AND SECTOR FORMAT 
(ST412/ST412R Interface drives) 

The standard track format for Winchester Disk drives is organized into numbered data segments, 
or sectors. 

INDEX-GAP | GAP-1 | ID-HELD | GAP-2 | DATA-HELD | GAP-3 | GAP-4 



< One SECTOR > 

(repeated n times) 

Standard Winchester Disk Sector Format 

OMTI 5510, 5520, 5520 A, 5526 : The nominal track capacity of an ST506/412 drive 
transferring data at 5 megabit/second is 10,416 bytes. The method of encoding used is Modified 
Frequency Modulation (MFM). 
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ADR 


PLO 


ADDRESS 


DATA 




DATA 


DATA 


FORMAT 


KG 


SYNC 


MARK 


1DMARK 




ADDR 


PAD 


SYNC 


MARK 


MARK 




CHECK 


PAD 


SPEED 


11 Byt«s 


12 Bylts 


lBylt 


lByl« 


ADDRESS 


CHECK 


2ByUs 


12 Bytes 


lByt* 


lByt« 


DATA 


ECC 


2 Bytes 


TOLERANCE 


4E 




Al 


FE 


FIELD 




00 




Al 


F8 


FIELD 




00 


GAME 



CYLINDER 
MSB 



CYLINDER 
LSB 



HEAD 



SECTOR 



JUMPER SELECTABLE; 256, 512 or 1024 BYTES PER SECTOR 

(D 4 BYTES, ECC o» OMTI 5510, 5520, 5520A , 5526 
2 BYTES, CRC on OMTI 5527 , 5527A 

® 4 BYTES, ECC on OMTI 5510, 5520, 5520A , 5526 
6 BYTES, ECC on OMTI 5527 , 5527A 

14 BYTES witL 256 or 512 BYTES/SECTOR 
22 BYTES witli 1024 BYTES/SECTO 



2.5 PIN ASSIGNMENTS 

The following tables define the various Floppy Disk Drive's pin assignments . 

2.5.1. FLOPPY DRIVE CONTROL AND DATA CONNECTOR (Jl) PIN 
DESCRIPTION 



SIG 


SIG 


SIGNAL 


SIGNAL 


I/O 




GND 


PIN 


MNEMONIC 


NAME 






1 


2 


WCCNTRL- 


WRITE 

CURRENT- 

CONTROL- 







1 

5 


4 


NC 








6 


NC 








7 


8 


INDEX- 


INDEX- 


I 




9 


10 


MOTEN1- 


MOTOR- 
ENABLE1- 







15 


16 


MOTEN2- 


MOTOR- 
ENABLE2- 







11 


12 


DS2- 


DRIVE- 
SELECT2- 







13 


14 


DS1 


DRIVE- 
SELECT1- 







17 


18 


DIR 


DIRCTION 







19 


20 


STEP- 


STEP- 
PULSE- 







21 


22 


WRT DATA- 


WRITE 
DATA- 







23 


24 


WRT EN- 


WRITE- 
DATA- 







25 


26 


TRKO 


TRACKO 


1 




27 


28 


WRT PROT 


WRITE 
PROTECT 


1 




29 


30 


READ DATA 


READ DATA 


1 




31 


32 


HS1 


HEAD SELECT1 







33 


34 


DISKETTE 
CHG 


DISKETTE 
CHANGE 


1 





Pin One is designated by a square backing on the solder side of the board. 
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2.5.2. ST506/412 Winchester Disk Drive Interface (all products) 

ST412 COMPATIBLE DISK DATA SIGNAL CONNECTOR (J3 &J4) RADIAL 

PINS FIXED DISKS 



1 


DRIVE SELECTED 


2 


GROUND 


3 


Reserved 


4 


GROUND 


5 


Reserved 


6 


GROUND 


7 


Reserved 


8 


GROUND 


9 


Reserved 


10 


Reserved 


11 


GROUND 


12 


GROUND 


13 


+MFM or 2,7 RLL WRITE DATA 


14 


-MFM or 2,7 RLL WRITE DATA 


15 


GROUND 


16 


GROUND 


17 


+MFM or 2,7 RLL READ DATA 


18 


-MFM or 2,7 RLL READ DATA 


19 


GROUND 


20 


GROUND 



ST412 COMPATIBLE DISK CONTROL SIGNAL CONNECTOR (J5). CHAINED. 

PINS FIXED DISKS 

GND 



GND 



1 2 


HEAD SELECT 3/WSI 


3 4 


HEAD SELECT 2 


5 6 


WRITE GATE 


7 8 


SEEK COMPLETE 


9 10 


TRACK 000 


11 12 


WRITE FAULT 


13 14 


HEAD SELECT 


15 16 


Reserved 


17 18 


HEAD SELECT 1 


19 20 


INDEX 


21 22 


READY 


23 24 


STEP 


25 26 


DRIVE SELECT 1 


27 28 


DRIVE SELECT 2 


29 30 


DRIVE SELECT 3 


31 32 


DRIVE SELECT 4 


33 34 


DIRECTION SELECT 



Pin One is designated by a square backing on the solder side of the board. 
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SECTION 3 
CONFIGURATION AND INSTALLATION 

3.1 Handling 

It is recommended that you handle the controller by the edges of the card as some of the 
components are static sensitive and can be damaged by static. 

3.2 Installation 

The OMTI 8240 Data Controller is designed to plug directly into any unused location on the 
system motherboard It is recommended that the controller be placed in the slot closest to 
the disk drive. The floppy and Winchester disk drives are connected to the controller by 
ribbon cables. 

3.3 Jumper Settings 

W 1 Winchester Primary/Secondary Address setting 

Primary Address 

1 Secondary Address 

W2 Floppy Primary /Secondary Address setting 

Primary 

1 Secondary 

The controller is shipped from the factory with the primary addresses being used. The 
secondary addresses should only be necessary if you are using 2 controllers in your 
system. 

3.4 Installation of Controller in system with one Winchester drive. 

1. Cabling Requirements: 

- One (1) 34-pin straight through cable. 

- One (1) 20-pin straight through cable. 

2. Connect the floppy drive cable to position Jl on the 8240 controller. 

Refer to figure x.x for the location of connectors on your board. Pin 1 on all 
connectors is specified by a square solder pad, visible on the soldered side of the 
board. 

3. On Winchester drive: 

-install drive select jumper to lowest Drive Select (DSO or DS 1). 

4. Install the 34-pin Winchester drive interface cable to the J5 connector. 

-Install the 20-pin data cable to either the J3 or J4 connector. 

5 . Attach Winchester activity LED connector to J6. 

6. Install the controller in any available slot on the PC/AT motherboard. CAUTION: 
Power must be off! 
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7 . Insert system Diagnostic Diskette. 

8 . Turn on the power. 

9. Enter setup routine. 

10. Setup systems options. 

1 1 . Select proper Drive Type. Consult your Technical Reference Manual for further 
information on the parameters. BE SURE TO SELECT CORRECT DRIVE TYPE 
FOR YOUR DRIVE. 

12. There are two ways to format your drive: 

A) Insert the Advanced Diagnostics diskette to execute a low level format on your 
disk drive. This will format your drive with an interleave of 2: 1. 

B) For highest performance using a 1 : 1 interleave, insert the OMTI 1 : 1 Interleave 
Formatter diskette. Type FMTR. This will format your drive with an interleave 
of 1:1. 

1 3. Create a DOS partition by executing FDISK utility. 

1 4. Initialize the drive by executing the command: FORMAT C:/S (or FORMAT D:). 

15. Your Winchester should now be bootable drive C: (or D:). 
3.5 Installation of Two Drive System 

1 . On Winchester Drive: 

- Set Drive Select to DS1 (or DSO) on drive C:. 

- Set Drive Select to DS2 (or DS1) on drive D:. 

- Install termination resistor on drive at end of daisy chain cable. 

- Remove termination resistor on first drive on daisy chain cable. 

2 . Connect second drive to controller using 34-pin daisy chain straight through cable 
and one 20-pin straight through cable. 

3. Follow steps 7 to 15 as defined above in one drive system. 
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SECTION 4 

WINCHESTER SECTION 

8240 INTERFACE REGISTERS 

The OMTI 8240 contains 10 registers by which the host can communicate with the controller. This • 
section describes the registers and command set that are supported by the Winchester disk portion 
of the 8240 controller. 







The 8240 Register Addresses 










Table 4.1 










I/O Address 




Primary 


Secondary 

170 


Read 

Data Register 


Write 


1F0 


Data Register 


1F1 


171 




Error Register 


Write Precomp 


1F2 


172 




Sector Count 


Sector Count 


1F3 


173 




Sector Number 


Sector Number 


1F4 


174 




Cylinder Number 
(LSB) 


Cylinder Number 
(LSB) 


1F5 


175 




Cylinder Number 
(MSB) 


Cylinder Number 
(MSB) 


1F6 


176 




SDH Select 


SDH Select 


1F7 


177 




Status 


Command 


Control and 


Status Registers 












I/O Address 




Primary 


Seconds 


ITY 


Bead 


Write 


3F2 


372 






Floppy Select/Control 


3F4 


374 




Main floppy status 




3F5 


375 




Floppy Data 


Floppy Data 


3F6 


376 




Secondary status 


Control Register 


3F7 


377 




Head/Select status 


Floppy Control 



4.1 Read Register Definitions 

4.1.1 Data Register 1F0 (170) 

This register transfers controller data between the Host and the 8240. In Word Mode, 16 bits of 
data are transferred requiring I/OCS16 to be asserted and possibly deasserting I/OCHRDY. 
In Byte Mode, 8 bits of data are transferred leaving I/0_CS_16 deasserted and I/0_CH_RDY 
asserted. 
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4.1.2 Error Register 1F1 (171) 

This register contains the error status of the last command executed by the controller. It can only 
be accessed while the controller is in the NOT BUSY state. This register is not affected by a reset 
The data returned is only valid when the error bit is set 



Bit 7 - Bad Block Found 



Bit 6 - ECC Error 



Bit 5 • Not used 
Bit 4 • ID not found 

Bit 3 - Not used 

Bit 2 - Aborted Command 

Bit 1 - No Cylinder Zero 



Bit - No Data Mark Found 



This indicates that the specified sector has previously 
been formatted with the Bad Track flag set in the ID 
field. It is not possible to access data on this sector. 

This indicates that a non-zero syndrome was detected 
in a specified data field. If the data error was 
corrected by ECC, Bit 2 of the Status Register will 
also be set and the command will continue if more 
sectors are specified. If the data error was not 
corrected by ECC, bit of the Status Register will be 
set and the command terminated. 

Set to zero. 

This indicates that the controller was able to locate 
the correct cylinder and head number but was unable 
to locate the correct sector. An ID CRC error can 
also generate this error condition. 

Set to zero. 

The current command issued by the Host has been 
aborted due to an undefined Command, or a Write 
Fault/Not Ready condition exists on the selected 
drive. 

This indicates that during a recalibration command or 
if retries are enable no Cylinder 000 was detected. 
This error occurs after the controller issues 2048 step 
pulses towards cylinder 000 and the selected drive 
does not respond with the Track 000 signal. 

This indicates that the controller was able to locate 
the sector but was unable to locate the data mark 
associated with it. 



4.1.3 Sector Count Register 1F2 (172) 

The number of sectors transferred during a read, write, verify or format track command is 
determined by this register. A in the sector count register specifies a 256 sector transfer. The 
initialize drive characteristics command must be performed before a multiple sector transfer. 
During a format command the number of sectors per track must be loaded into this register before 
each format track. 
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4.1.4 Sector Number Register 1F3 (173) 

This register contains the current sector number being processed by the controller. It can only be 
accessed while the controller is in the Not Busy state. If an error condition exists this register 
contains the sector number in error. It is set to 1 after a Reset. 

4.1.5 Cylinder Number Register (LSB) 1F4 (174) 

This register contains the least significant byte of the current cylinder number. It can only be 
accessed while the controller is in the Not Busy state. If an error condition exists, this register 
contains the least significant byte of the cylinder number in error. This register is set to after a 
Reset. 

4.1.6 Cylinder Number Register (MSB) 1F5 (175) 

This register contains the most significant byte of the current cylinder number. It can only be 
accessed while the controller is in the Not Busy state. If an error condition exists, this register 
contains the most significant byte of the cylinder number in error. This register is set to after a 
Reset. 

4.1.7 SDH Register 1F6 (176) 

This register contains the controller Error Code/Sector Size parameters along with the current 
Drive/Head select. It can only be accessed when the controller is Not Busy. This register is set to 
after a reset 

Bit Definition 

7 Set to 1 the data field will be appended with an ECC field 

Set to the data field will be appended with a CRC field. 

6 and 5 These bits indicate the sector size selected Their definitions are: 

6 5 

- 256 Bytes per Sector 

1-512 Bytes per Sector 

1 0-1024 Bytes per Sector 
1 1-128 Bytes per Sector 

4 Drive Select 

is Drive 

1 is Drive 1 

3-0 Head Select Bit 3 is the MSB with Bit being the LSB. 
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4.1.8 Status Register 1F7 (177) 



The status of the command is reported in this register after its execution. A read of this register 
clears interrupt request. Bit Definition: 



Busy 



6 

5 



Ready. 
Write Fault. 



This bit indicates the state of the controller. If set, the controller is 
busy executing the specified command and is not in a data transfer 
state. Any write to the Host Read/Write registers while this bit is set 
will be ignored. If cleared the controller is either in a Not Busy or a 
Data Transfer state. The DRQ bit will be set if the controller is in the 
Data Transfer state. 

This bit is an inverted copy of the Ready signal of the selected drive. 

This bit is an inverted copy of the Write Fault signal of the selected 
drive. 



Seek Complete This bit is an inverted copy of the Seek Complete signal of the selected 
drive. 

This bit indicates that the controller is in a Data Transfer mode. While 
this bit is set, the Busy bit will be cleared and the controller will wait 
for data to be transferred to or from the host. 

When this bit is set it indicates the data read from the disk was 
properly corrected with the use of ECC. If CRC is selected, this bit 
has no meaning and is set to zero. 

This bit is set on each revolution of the disk. 

When set to 1 this indicates the previous command ended in an error 
and that the error register has been set. The next command clears this 
bit. 

4.1.9 Secondary Status Register 3F6 (376) 

This register contains the Controller/Drive status. It is identical to the Status Register at 1F7 (177). 

4.1.10 Head\Select Status Register 3F7 (377) 

This register contains the Head/Drive Select status. The bit definitions are: 



3 


Data Request. 


2 


Corrected 


1 


Index. 





Error. 



Bit 7 - Diskette Change 

Bit 6 - Write Gate 

Bit 5 - Head Select 3/RWC 



This bit indicates the state of the floppy Disk Change 
signal If set, no diskette, door open or Drive Not 
Ready condition. 

This bit indicates the state of the Winchester Write 
Gate signal'. 

This bit indicates the state of Head Select 
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Bit 4 - Head Select 2 This bit indicates the state of Head Select 2. 

Bit 3 - Head Select 1 This bit indicates the state of Head Select 1. 

Bit 2 • Head Select This bit indicates the state of Head Select 0. 

Bit 1 - Drive Select 1 This bit indicates the state of Drive Select 1. If set to 

0, Drive 1 is selected. 

Bit - Drive Select This bit indicates the state of Drive Select 0. If set to 

Dive is selected. 

4.2 8240 Write Register Definitions 

4.2.1 Data Register 1F0 (170) 

This register transfers controller data between the 8240 and the HOST. In WORD MODE, 16 bits 
of data are transferred requiring I/OCS_16 to be asserted and possibly de-asserting 
I/0_CH_RDY. In BYTE MODE, 8 bits of data are transferred leaving 1/0 CS_16 deasserted and 
I/0_CH_RDY asserted. 

4.2.2 Write Precompensation/RWC Register 1F1 (171) 

This register determines the cylinder at which Write Precompensation will be applied. The value 
written is 1/4 the actual precompensation cylinder. A value of 255 will result in no write 
precompensation/reduce write current This register should be written prior to the Command 
Register being written with a Write/Format command. It is set to 32 (128) after a Reset 

4.2.3 Sector Count Register 1F2 (172) 

The number of sectors transferred during a read, write, verify or format track command is 
determined by this register. A in the sector count register specifies a 256 sector transfer. The 
initialize drive characteristics command must performed before a sector transfer. During a format 
command the number of sectors per track must be loaded into this register before each format 
track. 

4.2.4 Sector Number Register 1F3 (173) 

This register specifies the starting sector number. It should be written prior to the Command 
Register being written. This register is set to 1 after a reset 

4.2.5 Cylinder Number Register (LSB) 1F4 (174) 

This register specifies the least significant byte of the starting cylinder number. It should be 
written prior to the Command register being written. This register is set to after a Reset. 



OMTI 8240 Controller Series - Revision A - Page 4-5 



4.2.6 Cylinder Number Register (MSB) 1F5 (175) 

This register specifies the most significant byte of the starting cylinder number. It should be 
written prior to the Command Register being written. This register is set to after a Reset. 

4.2.7 SDH Register 1F6 (176) 

This register specifiess the controller Error Code/Sector Size parameters along with the 
Drive/Head select. This register should be written prior to the Command Register being written. 
This register is set to after a Reset. Thebit definitions are: 

Bit Definition 

7 This bit specifies the error code to be selected. If this bit is set the data field will be 

appended with an ECC field. If cleared the data field will be appended with a CRC 
field. 

6 and 5 These bits indicate the sector size selected. Their definitions are: 

6 5 

0-256 Bytes per Sector 

1-512 Bytes per Sector 

1 0-1024 Bytes per Sector 
1 1-128 Bytes per Sector 

4 Drive Select 

is Drive 

1 is Drive 1 

3-0 Head Select Bit 3 is the MSB with Bit being the LSB. 
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4.2.8 Command Register 1F7 (177) 



This register accepts only 8 commands for Winchester operations. The following table lists the 
commands supported. 



Command 

Recalibrate 

Seek 

Read 

Write 

Format Track 

Read Verify 

Diagnostic 

Set Parameters 



Bit 

7 


Bit 
6 


Table 
Bit 

5 


4.2 
Bit 

4 


Bit 

3 


Bit 

2 


Bit 

1 


Bit 















S3 


S2 


SI 


SO 





1 


1 




S3 


S2 


SI 


SO 








1 











L 


R 








1 










L 


R 





1 






















1 

















R 


1 






















1 



















1 



L 
R 



When set to 1 a Read or Write Long has occuired and 4 ECC bytes will be 

transferred. 

When set to 1 Retries are disabled. 



S 3 - S Table 5.3 defines the step rates supported. 









Table 5.3 




S3 


S2 


SI 


SO 


Step Ra 














35 usee 











1 


0.5 msec 








1 





1.0 msec 








1 


1 


1.5 msec 





1 








2.0 msec 





1 





1 


2.5 msec 





1 


1 





3.0 msec 





1 


1 


1 


3.5 msec 













4.0 msec 










1 


4.5 msec 







1 





5.0 msec 







1 


1 


5.5 msec 




1 








6.0 msec 




1 





1 


6.5 msec 




1 


I 





7.0 msec 




1 


1 


1 


7.5 msec 



After a diagnostic or reset the step rate defaults to 7.5 msec. 
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4.2.9. Recalibrate 

The drive specified is stepped toward the outside cylinder until either Track Zero signal is detected 
or more steps have been issued than available cylinders for the device type. The controller issues 
one step pulse, waits for seek complete, and tests the Track 000 signal. 

4.2.10. Seek 

This command causes the read/write heads to be physically positioned to the cylinder specified in 
the cylinder high and low registers. The implied seek step rate is also set by this command with 
the lower four bits of the command used to select the step rate. If executed in the buffered mode 
step pulses and command complete will be issued before the seek is complete allowing an 
overlapped seek. 

4.2.11. Read Sector 

This command specifies the number of sectors (1-256) to be read from the Winchester Disk with or 
without the ECC field appended (ECC field is appended if Read Long bit is set). The sector count 
register determines the number of sectors to be transferred. If a read is issued prior to 
initializatiion of a step rate the default value will be used. If the retries bit is set to up to ten 
retries will be performed before an error is reported. If the retries bit is set to 1 only two retries 
will be executed. Interrupts occur as each sector is ready to be read, there is no interrupt at the end 
of a command. 

4.2.12. Write Sector 

This command specifies the number of sectors (1-256) to be written to the Winchester Disk with or 
withoutthe ECC Bytes appended by the Host (ECC field is appended if Write Long bit is set). The 
sector count register is used to determine the number of sectors to be transferred. If a write is 
issued prior to initialization of a step rate the default value is used If the retries bit is set to up to 
ten retries will be performed before an error is reported. If the retries bit is set to 1 only two retries 
will be executed. Interrupts are generatedas each sector is transferred into the Sector Buffer 
(except the first sector) and at the end of the command. 

4.2.13. Format Track 

The track specified in the task file is formatted with ID and data fields according to the interleave 
table that is transferred to the buffer. The sector count register must be loaded with the number of 
sectors per track before each Format Track command. An interrupt is generated at the end of this 
command. There are no valid errors for this command. 

4.2.14. Read Verify 

This command is similiar to a read sector with the difference being that no data is transferred 
during a read verify. If this command is issued prior to initialization of a step rate the default value 
of X.X msec is used and a recalibrate is performed first. Any number of sectors may be 
transferred up to 256, the ECC bytes generated are compared with those that were recorded to 
verify data integrity. An interrupt is generated at the end of this command or when an error is 
encountered. 
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4.2.15. Diagnostic 

This command causes the Controller to perform an onboard diagnostic and report the result in the 
Error Register. This command tests the Interface, Buffer, RAM, Sequencer and ROM. The error 
codes that can be reported in the error register are: 

01 NO ERROR 

2 CONTROLLER INTERFACE FAILURE 

3 CONTROLLER BUFFER RAM FAILURE 

4 SEQUENCER FAILURE 

5 CONTROLLER ROM FAILURE 



Set Parameters 

This command sets up the drive parameters specifying the maximum number of heads and sectors 
per track. This command must be issued before any multiple sector operations are begun. The 
drive/head select register should be used to specify the drive which is having its parameters set, 
this allows drives to have different parameters. 
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SECTION 5 
5.1. FLOPPY DISK REGISTERS 

There are five I/O registers (eight bits) which the host accesses to communicate with the floppy 
disk portions of the OMTI 8240 controller. The address of these registers is selectable (re: Section 
3) to be either at the primary or secondary location as shown in table 4-1. 

Table 4-1 



| I/O Address 

| Primary Secondary 


Read 


Write | 


1 3F2 H 


372 H 




Floppy Select/ j 
Control | 


1 3F4 H 


374 H 


Main Floppy 
Status 


Main Floppy | 
Status | 


1 3F5 H 


375 H 


Floppy Data 


Floppy Data | 


1 3F6 H 


376 H 


Secondary 
Status 


Control Register | 


1 3F7 H 


1 377 H 

1 


Head/Select 
Status 


Rate Select | 



The host uses the Main Floppy Status and Data Register to issue commands to and receive status 
from the controller. The Digital Input, Digital Output and Diskette Control Register and Additional 
Control Registers are used to control the specific drive functions as shown: 



Read 
Register 



Definition 



Main Floppy 
Status 

(3F4/374) 



This is a read only register used in conjuntion with the Data 
register to transfer commands to the controller. 

Bit 7 Request for Master (RQM). Indicates that the data register is ready 

to send or receive data. This bit must be used by the host to perform 
handshaking functions between the host and controller. This bit is 
cleared by reading or writing the Data Register. 

Bit 6 Data In/Out (DIO) indicates direction of data transfer. If DIO = 1 
then transfer is from the Data Register to the host. If DIO = then it 
is from the host to the Data Register. 

Bit 5 Non-DMA mode when 1. This can occur only during execution 
phase. 

Bit 4 When 1 the controller is busy executing a command. 
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Bit 3,2 Reserved 

Bit 1 Drive B is in the Seek mode when 1. 

BitO Drive A is in the Seek mode when 1. 



WFIt? 

Register 



Definition 



Floppy Select/Control 

(3F2/372) 



Floppy Rate Select 

(3F7/377) 



Read/Write 
Register 



This is an output only register used to control drive motors, drive 
selection, interrupts/DMA and reset All bits are cleared when a 
channel reset occurs. 

Bit 7 Reserved 

Bit 6 Reserved 

Bit 5 Drive B Motor Enable when 1 

Bit 4 Drive A Motor Enable when 1 

Bit 3 Interrupts and DMA enable when 1 

Bit 2 Reset floppy disk function when 0. The floppy disk function 
comes out of reset when this bit is set to 1 

Bit 1 Reserved 

Bit Select Drive-A. A selects drive A, A 1 selects drive B 

This is an output only register which gives the controller data 
rate information. All bits are cleared when a channel reset occurs. 

Bits 2-7 Reserved. 

Bits 1 Data Rate 

500 Kbits/sec 

1 300 Kbits/sec 

1 250 Kbits/sec 
1 1 Reserved 

Definition 



Floppy Data 
(3F5/375) 



This register is used to transfer information to/from the host This 
register can be logically viewed as several registers in a stack with 
only one presented at any time. Data bytes are read out of or written 
into the Data register in order to program a command or obtain the 
results after the execution of a command. 
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5.2 FLOPPY DISK PROTOCOL 

The host sends commands to the controller by sending several bytes of information to the 
controller (via the Data register) synchronized with bits 6 and 7 in the Status register. The sending 
of command data is called the command phase. The controller then goes "Busy" and executes the 
command (the command phase). Upon completion of the command the controller becomes "not 
busy" and results may be obtained from the Data register again synchronized with bit 6 and 7 in the 
Status register. Floppy commands, parameters and results are listed in section 4.5. 

FLOPPY DISK FUNCTIONS 

5.3 FLOPPY DISK COMMAND SUMMARY 

The following is a list of commands that may be issued to the Floppy section of the combination 
disk controller. 

READ DATA 

FORMAT TRACK 

SCAN EQUAL 

SCAN LOW OR EQUAL 

SCAN HIGH OR EQUAL 

RECALIBRATE 

SENSE INTERRUPT STATUS 

SPECIFY 

SENSE DRIVE STATUS 

SEEK 

INVALID 
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5.4 DESCRIPTION OF SYMBOLS 

The following are descriptions of the symbols used in the "Command Definitions" later in this 
section. 

AO Address line 0- A0 selects the main status register, and a 1 selects the data register. 

C Cylinder Number-Contains the current or selected cylinder number in binary notation. 

D Data-Contains the data pattern to be written to a sector. 

D7-D0 Data Bus- An 8-bit data bus in which D7 is the most significant bit and DO is the least- 
significant 

DTL Data Length- When N is 00, DTL is the data length to be read from or written to a 

sector. 

EOT End of Track- The final sector number on a cylinder. 

GPL Gap Length - The length of gap 3 (spacing between sectors excluding the VCO 

synchronous field). 

H Head Address - The head number, either or 1, as specified in the E) field. 

HD Head - The selected head number, either or 1. (H=HD in all command words). 

HLT Head Load Time - The head load time in the selected drive (2 to 256 millisecond 

increments for the 1.2Mbyte drive and 4 to 512 milliseconds in 4 millisecond increments 
for the 320K-byte drive). 

HUT Head Unload Time - The head unload time after a read or write operation (0 to 240 
milliseconds in 16 millisecond increments for the 1.2M-byte drive and to 480 milli- 
seconds in 32 millisecond increments for the 320K-byte drive. 

MF FM or MFM Mode - A0 selects FM mode and a 1 selects MFM. ( MFM is selected only 

if it is implemented). 

MT Multitrack - Al selects multitrack operation. (Both HDO and HD1 will be read or 

written). 

N Number - The number of data bytes written in a sector. 

NCN New Cylinder - The new cylinder number for a seek operation. 

ND Non-Data Mode - This indicates an operation in the non-data mode. 

PCN Present Cylinder Number - The cylinder number at the completion of a Sense interrupt 

status command (present position of the head). 

R Record - The sector number to be read or written. 
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R/W Read/Write - This stands for either a 'read' or 'write' signal. 

SC Sector - The number of sectors per cylinder. 

SK Skip - This stands for skip deleted-data address mark. 

SRT This 4 bit byte indicates the stepping rate for the diskette drive as follows: 

1.2M-Byte Diskette Drive 

1111 1 millisecond 

1110 2 milliseconds 
1101 3 milliseconds 

320K-Byte Diskette Drive 

1111 2 milliseconds 
1110 4 milliseconds 
1101 6 milliseconds 

ST0-ST1 Status 0-Status 3 - One of the four registers that stores status information after a 
command is completed. 

STP Scan Test - If STP is 1 , the data in contiguous sectors is compared with the data sent by 

the processor during a scan operation. If STP is 2, then alternate sectors are read and 
compared. 

USO-US 1 Unit Select - The selected driver number encoded the same as bits and 1 of the digital 
output register (DOR). 

5.5. FLOPPY COMMANDS 

The following are commands that may be issued to the floppy section of controller. 
NOTE: An X is used to indicate a don't care condition. 

5.5.1. READ DATA command 

Command Phase : The following bytes are issued by the processor in the command phase: 
MT MF SK 1 1 

XX X X X HD US1 USO 
C 
H 
R 
N 

EOT 
GPL 
DTL 

Result Phase : The following bytes are issued by the controller in the result phase: 
STO 
ST1 
ST2 
C 
H 
R 
N 
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5.5.2 FORMAT A TRACK Command 

Command Phase: The following bytes are issued by the processor in the command phase 
MF 1 1 

XX X X X HD US1 USO 
N 
SC 
GPL 
D 

Result Phase: The following bytes are issued by the controller in the result phase: 
STO 
ST1 
ST2 
C 
H 
R 
N 

5.5.3 SCAN EQUAL Command 

Command Phase: The following bytes are issued by the processor in the command phase: 
MT MF SK 1 1 

XX X X X HD US1 USO 
C 
H 
R 
N 

EOT 
GPL 
STP 

Result Phase: The following bytes are issued by the controller in the result phase: 
STO 
ST1 
ST2 
C 
H 
R 
N 

5.5.4. SCAN LOW OR EQUAL Command 

Command Phase: The following bytes are issued by the processor in the command phase: 
MT MF SK 1 1 1 

XX X X X HD US1 USO 
C 
H 
R 
N 

EOT 
GPL 
STP 



OMTI 8240 Controller Series - Revision A - Page 5-6 



Result Phase: The following bytes are issued by the controller in the result phase: 
STO 
ST1 
ST2 
C 
H 
R 
N 



5.5.5. SCAN HIGH OR EQUAL Command 

Command Phase: The following bytes are issued by the processor in the command phase: 
MT MF SK 1 11 1 

X X X X X HD US1 USO 
C 
H 
R 
N 

EOT 
GPL 
STP 

Result Phase: The following bytes are issued by the controller in the result phase: 
STO 
ST1 
ST2 
C 
H 
R 
N 

5.5.6. RECALIBRATE Command 

Command Phase: The following bytes are issued by the processor in the command phase: 
111 

X X X X X US1 USO 

Result Phase: This command has no result phase. 

5.5.7. SENSE INTERRUPT STATUS Command 

Command Phase: The following bytes are issued by the processor in the command phase: 
10 

Result Phase: The following bytes are issued by the controller in the result phase: 
STO 
PCN 



OMTI 8240 Controller Series - Revision A - Page 5-7 



5.5.8. SPECIFY Command 

Command Phase: The following bytes are issued by the processor in the command phase: 
1 1 

( SRT )( HUT ) 
( HLT ) ND 

Result Phase: This command has no result phase. 

5.5.9. SENSE DRIVER STATUS Command 

Command Phase: The following bytes are issued by the processor in the command phase: 
10 

XX X X X HD US1 USO 

Result Phase: The following bytes are issued by the controller in the result phase: 
ST3 

5.5.10. SEEK Command 

Command Phase: The following bytes are issued by the processor in the command phase: 

1111 

XX X X X HD US1 USO 

NCN 

Result Phase: This command has no result phase. 

5.5.11. INVALID Command 

Command Phase: The following bytes are issued by the processor in the command phase: 

Invalid Codes 

X X X X X HD US1 USO 

Result Phase: The following bytes are issued by the controller in the result phase: 
STO 

5.6. COMMAND STATUS REGISTERS 

The following is information about the command status registers STO through ST3. 

5.6.1. Command Status Register (STO) 

The following are bit definitions for command status register 0. 

Bit 7-Bit 6 Interrupt Code (IC) 

00 Normal Termination of Command (NT) - The command was completed and 
properly executed. 

1 Abrupt Termination of Command (AT) - The execution of the command was 
started but not successfully completed. 

10 Invalid Command Issue (IC) - The issued command was never started. 

1 1 Abnormal termination because, during the execution of a command, the 
■ready' signal from the diskette drive changed state. 
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Bit 5 Seek End (SE) - Set to 1 when the controller completes the Seek command 

Bit 4 Equipment Check (EC)- Set if a fault' signal is received from the diskette drive, or 

if the 'track-0' signal fails to occur after 77 step pulses (Recalibrate Command). 

Bit 3 and 2 Not Used - Always zero 

Bit 1-Bit Unit select 1 and 2 (US 1 and 2) - Indicate a drive's unit number at interrupt 

5.6.2. Command Status Register 1 (ST1) 

The following are bit definitions for command status registers 1. 

Bit 7 End of Cylinder (EC) - Set when the controller tries to gain access to a sector of a 

cylinder. 

Bit 6 Not Used- Always 0. 

Bit 5 Data Error PE) - Set when the controller detects a CRC error in either the ID field or 

the data field 

Bit 4 Overrun (OR) - Set if the controller is not serviced by the main system within a 

certain time limit during data transfers. 

Bit 3 Not Used - This bit is always set to 0. 

Bit 2 No Data (ND) - Set if the controller cannot find the sector specified in the ID register 

during the execution of a Read Data, Write Deleted Data, or Scan Command. This 
flag is also set if the controller cannot read the ID field without an error during the 
execution of a Read ID command or if the starting sector cannot be found during the 
execution of a Read Cylinder command. 

Bit 1 Not Writeable (NW) - Set if the controller detects a 'write-protect' signal from the 

diskette drive during execution of a Write Data, Write Deleted Data, or Format 
Cylinder command. 

Bit Missing Address Mark (MA) - Set if the controller cannot detect the ID address 

mark. At the same time, the MD of status register 2 is set. 

5.6.3. Command Status Register 2 (ST2) 

Bit 7 Not Used - Always zero. 

Bit 6 ****control Mark (CM) - This flag is set if the controller encounters a sector that has 

a deleted data-address mark during execution of a Read Data or Scan command. 

Bit 5 Data Error in Data Field (DD) - Set if the controller detects an error in the data. 

Bit 4 Wrong Cylinder (WC) - This flag is related to ND (no data) and when the contents 

of Con the medium arc different from that stored in the ID register, this flag is set. 

Bit 3 Scan Equal Hit (SH) - Set if the contiguous sector data equals the processor data 

during the execution of a Scan command. 
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Bit 2 Scan Not Satisfied (SN) - Set if the controller cannot find a sector on the cylinder 

that meets the condition during a Scan command. 

Bit 1 Bad Cylinder (BC) - Related to ND; when the contents of C on the medium are 

different from that stored in the ID register, and the contents of C is FF, this flag is 
set 

Bit Missing Address Mark in Data Field (MD) Set if the controller cannot find a data 

address mark or a deleted data address mark when data is read from the medium. 

5.6.4. Command Status Register 3 (ST3) 

The following are bit definitions for command status register 3. 

Bit 7 Not used - always zero. 

Bit 6 Write Protect (WP) - Status of the 'write-protect' signal from the diskette drive. 

Bit 5 Not used - always zero. 

Bit 4 Track (TO) - Status of the 'ready' signal from the diskette drive. 

Bit 3 Not used - always zero. 

Bit 2 Head Address (HD) - Status of the 'side-select' signal to the diskette drive. 

Bit 1 Not used - always zero. 

Bit Not used - always 1. 
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